I2C Repeater Click
I2C Repeater Click demo application is developed using the NECTO Studio, ensuring compatibility with mikroSDK's open-source libraries and tools. Designed for plug-and-play implementation and testing, the demo is fully compatible with all development, starter, and mikromedia boards featuring a mikroBUS™ socket.
Click Library
- Author : Stefan Filipovic
- Date : Jul 2025.
- Type : I2C type
Software Support
Example Description
This example demonstrates the communication through the I2C Repeater Click board. It initializes the device, sets the slave I2C address of an external I2C sensor (e.g. 6DOF IMU 11 Click), and reads its device ID register, verifying if the expected ID is returned.
Example Libraries
- MikroSDK.Board
- MikroSDK.Log
- Click.I2CRepeater
Example Key Functions
- i2crepeater_cfg_setup This function initializes Click configuration structure to initial values.
void i2crepeater_cfg_setup(i2crepeater_cfg_t *cfg)
I2C Repeater configuration object setup function.
I2C Repeater Click configuration object.
Definition i2crepeater.h:122
- i2crepeater_init This function initializes all necessary pins and peripherals used for this Click board.
err_t i2crepeater_init(i2crepeater_t *ctx, i2crepeater_cfg_t *cfg)
I2C Repeater initialization function.
I2C Repeater Click context object.
Definition i2crepeater.h:105
- i2crepeater_enable_device This function enables the device by setting the EN pin to high logic state.
void i2crepeater_enable_device(i2crepeater_t *ctx)
I2C Repeater enable device function.
- i2crepeater_set_i2c_address This function sets the slave address for I2C communication.
err_t i2crepeater_set_i2c_address(i2crepeater_t *ctx, uint8_t slave_addr)
I2C Repeater set I2C address function.
- i2crepeater_i2c_read_reg This function reads data from a specific register of the I2C slave.
err_t i2crepeater_i2c_read_reg(i2crepeater_t *ctx, uint8_t reg, uint8_t *data_out, uint8_t len)
I2C Repeater read register function.
Application Init
Initializes the logger and the I2C Repeater Click, then enables the device.
{
log_cfg_t log_cfg;
LOG_MAP_USB_UART( log_cfg );
log_init( &logger, &log_cfg );
log_info( &logger, " Application Init " );
{
log_error( &logger, " Communication init." );
for ( ; ; );
}
log_info( &logger, " Application Task " );
}
#define I2CREPEATER_MAP_MIKROBUS(cfg, mikrobus)
MikroBUS pin mapping.
Definition i2crepeater.h:92
void application_init(void)
Definition main.c:38
Application Task
Sets the I2C address of a connected I2C sensor and reads its device ID, then logs whether the returned ID matches the expected value.
{
uint8_t device_id = 0;
{
{
log_printf( &logger, " %s - Device ID: 0x%.2X - %s\r\n\n",
(
char * ) ( (
DEVICE_ID == device_id ) ?
"OK" :
"NOK" ) );
}
Delay_ms ( 1000 );
}
}
@ I2CREPEATER_OK
Definition i2crepeater.h:139
#define DEVICE_ID
Definition main.c:33
void application_task(void)
Definition main.c:70
#define DEVICE_NAME
Definition main.c:30
#define DEVICE_SLAVE_ADDRESS
Definition main.c:31
#define DEVICE_REG_ID
Definition main.c:32
Note
Make sure to provide the power supply to VCCB side for the connected I2C sensor.
Application Output
This Click board can be interfaced and monitored in two ways:
- Application Output - Use the "Application Output" window in Debug mode for real-time data monitoring. Set it up properly by following this tutorial.
- UART Terminal - Monitor data via the UART Terminal using a USB to UART converter. For detailed instructions, check out this tutorial.
Additional Notes and Information
The complete application code and a ready-to-use project are available through the NECTO Studio Package Manager for direct installation in the NECTO Studio. The application code can also be found on the MIKROE GitHub account.